<template>
  <div class="user-profile">
    <div class="info">
      <van-image round :src="userInfo.photo" />
      <h3 class="name">
        {{userInfo.name}}
        <br />
        <van-tag size="mini">申请认证</van-tag>
      </h3>
    </div>
    <van-row>
      <van-col span="6">
        <p>{{userInfo.art_count}}</p>
        <p>动态</p>
      </van-col>
      <van-col span="6">
        <p>{{userInfo.follow_count}}</p>
        <p>关注</p>
      </van-col>
      <van-col span="6">
        <p>{{userInfo.fans_count}}</p>
        <p>粉丝</p>
      </van-col>
      <van-col span="6">
        <p>{{userInfo.like_count}}</p>
        <p>被赞</p>
      </van-col>
    </van-row>

    <van-row class="user-links">
      <van-col span="8">
        <van-icon name="newspaper-o" color="#7af" />我的作品
      </van-col>
      <van-col span="8">
        <van-icon name="star-o" color="#f00" />我的收藏
      </van-col>
      <van-col span="8">
        <van-icon name="tosend" color="#fa0" />阅读历史
      </van-col>
    </van-row>

    <van-cell-group class="user-group">
      <van-cell icon="edit" title="编辑资料" to="/user/profile" is-link />
      <van-cell icon="chat-o" title="小智同学" to="/user/chat" is-link />
      <van-cell icon="setting-o" title="系统设置" is-link />
      <van-cell icon="warning-o" title="退出登录" is-link @click="logout" />
    </van-cell-group>
  </div>
</template>

<script>
import { mapMutations } from 'vuex'
import { getUserInfo } from '@/api/user'
export default {
  name: 'user-index',
  data () {
    return {
      // 登陆人信息
      userInfo: {}
    }
  },
  created () {
    this.getUser()
  },
  methods: {
    ...mapMutations(['delToken', 'setPhoto']),
    logout () {
      // 弹出确认框 dialog 组件 和toast组件使用相似
      this.$dialog.confirm({
        title: '温馨提示',
        message: '亲，您确认退出黑马头条吗？'
      }).then(() => {
        // 退出：删除vuex和本地的用户信息
        this.delToken()
        this.$toast.success('退出成功')
        this.$router.replace('/login')
      }).catch(() => {
        // click cancel
        // 取消登陆
        // console.log('取消登录')
        this.$toast.fail('取消退出')
      })
    },
    async getUser () {
      try {
        const { data } = await getUserInfo()
        // console.log(data)
        this.userInfo = data
        this.setPhoto(data.photo)
      } catch (error) {

      }
    }
  }
}
</script>

<style scoped lang='less'>
.user {
  &-profile {
    width: 100%;
    height: 150px;
    display: block;
    background: #3296fa;
    color: #fff;
    .info {
      display: flex;
      padding: 20px;
      align-items: center;
      .van-image {
        width: 64px;
        height: 64px;
      }
      .name {
        font-size: 16px;
        font-weight: normal;
        margin-left: 10px;
      }
      .van-tag {
        background: #fff;
        color: #3296fa;
      }
    }
    p {
      margin: 0;
      text-align: center;
    }
  }
  &-group {
    margin-bottom: 15px;
    text-align: left;
  }
  &-links {
    padding: 15px 0;
    font-size: 12px;
    text-align: center;
    background-color: #fff;
    .van-icon {
      display: block;
      font-size: 24px;
      padding-bottom: 5px;
    }
  }
}
</style>
